## **COMPUTER ARCHITECTURE**

## LAB #2 Assignment April 21, 2018

(Hassan Elseoudy 3780 / Merna Adel 4168 / Bavli George 3750 / Mahmoud Mohamed 2718)

1. Please indicate how many hours you spent on this lab. This will not affect your grade (unless omitted), but will be helpful for calibrating the workload for next semester's labs.

Answer: ~10 hours

2. A completed version of Table 1.

Note (X) -> not allowed in this instruction. Link

3. An image of the simulation waveforms showing correct operation of the processor. Does it write the correct value to address 84? Answer: yes





4. Marked up versions of the datapath schematic and decoder tables that adds the ori and bne instructions.

## **Extended functionality. Main Decoder:**

| Instruction | Op5:0  | RegWrite | RegDst | AluSrc | Branch | MemWrite | MemtoReg | ALUOp <sub>1:0</sub> | Jump | One/Z |
|-------------|--------|----------|--------|--------|--------|----------|----------|----------------------|------|-------|
| R-type      | 000000 | 1        | 1      | 0      | 0 0    | 0        | 0        | 10                   | 0    | 0     |
| lw          | 100011 | 1        | 0      | 1      | 0 0    | 0        | 1        | 00                   | 0    | 0     |
| sw          | 101011 | 0        | X      | 1      | 0 0    | 1        | X        | 00                   | 0    | 0     |
| beq         | 000100 | 0        | X      | 0      | 1 0    | 0        | X        | 01                   | 0    | 0     |
| addi        | 001000 | 1        | 0      | 1      | 0 0    | 0        | 0        | 00                   | 0    | 0     |
| j           | 000010 | 0        | X      | X      | XX     | 0        | X        | XX                   | 1    | 0     |
| ori         | 001101 | 1        | 0      | 1      | 0.0    | 0        | 0        | 11                   | 0    | 1     |
| bne         | 000101 | 0        | X      | 0      | 11     | 0        | X        | 01                   | 0    | 0     |

## Extended functionality. ALU Decoder:

| ALUOp <sub>1:0</sub> | Meaning             |
|----------------------|---------------------|
| 00                   | Add                 |
| 01                   | Subtract            |
| 10                   | Look at funct field |
| 11                   | ORI                 |





5. Your SystemVerilog code for your modified MIPS computer (including ori and bne functionality) with the changes highlighted and commented in the code.

Project Link: <a href="https://github.com/Hassan-Elseoudy/MIPS-SingleCycle">https://github.com/Hassan-Elseoudy/MIPS-SingleCycle</a>

```
6'b000000: controls <= 11'b11000000100; // RTYPE
6'b100011: controls <= 11'b10100100000; // LW
6'b101011: controls <= 11'b001001000000; // SW
6'b000100: controls <= 11'b00010000010; // BEQ
6'b001000: controls <= 11'b101000000000; // ADDI
6'b000101: controls <= 11'b101000000111; // ORI
6'b000101: controls <= 11'b10100000100; // BNE
default: controls <= 11'bxxxxxxxxxxxx; // illegal op
```

6. The contents of your memfile2.dat containing your test2 machine language code

```
34088000
20098000
350a8001
11090005
0128582a
15600001
08000009
01485022
350800ff
016a5820
01484022
ad680052
```